<?xml version = '1.0' encoding = 'UTF-8'?>
<HBRRepo><variables><variable name="OQP_BestCasePer" type="num" usage="const" id="1" product="Planning"><property name="application">SalesPln</property><property name="plantype">OEP_QTP</property><property name="prompt_text">Best Case +/- Base Plan Percentage</property><property name="scope">ruleset</property><property name="seeded">true</property><value>5</value><limits type="minmax"><property name="min">-100</property><property name="max">100</property></limits></variable><variable name="OQP_ConservativePer" type="num" usage="const" id="2" product="Planning"><property name="application">SalesPln</property><property name="plantype">OEP_QTP</property><property name="prompt_text">Conservative +/- Base Plan Percentage</property><property name="scope">ruleset</property><property name="seeded">true</property><value>3</value><limits type="minmax"><property name="min">-100</property><property name="max">100</property></limits></variable><variable name="OQP_WorstCasePer" type="num" usage="const" id="3" product="Planning"><property name="application">SalesPln</property><property name="plantype">OEP_QTP</property><property name="prompt_text">Worst Case +/- Base Plan Percentage</property><property name="scope">ruleset</property><property name="seeded">true</property><value>-5</value><limits type="minmax"><property name="min">-100</property><property name="max">100</property></limits></variable></variables><rulesets/><rules><rule id="1" name="OQP_Set Target What If" product="Planning"><property name="application">SalesPln</property><property name="plantype">OEP_QTP</property><property name="seeded">true</property><variable_references><variable_reference name="OQP_WorstCasePer" id="3"><property name="application">SalesPln</property><property name="hidden">false</property><property name="plantype">OEP_QTP</property><property name="rule_name">OQP_Set Target What If</property><property name="seq">1</property><property name="type">1</property><property name="useAsOverrideValue">false</property></variable_reference><variable_reference name="OQP_BestCasePer" id="1"><property name="application">SalesPln</property><property name="hidden">false</property><property name="plantype">OEP_QTP</property><property name="rule_name">OQP_Set Target What If</property><property name="seq">2</property><property name="type">1</property><property name="useAsOverrideValue">false</property></variable_reference><variable_reference name="OQP_ConservativePer" id="2"><property name="application">SalesPln</property><property name="hidden">false</property><property name="plantype">OEP_QTP</property><property name="rule_name">OQP_Set Target What If</property><property name="seq">3</property><property name="type">1</property><property name="useAsOverrideValue">false</property></variable_reference></variable_references><script type="groovy">			/*RTPS:{OQP_BestCasePer} {OQP_ConservativePer} {OQP_WorstCasePer} */
			/*PURPOSE: This rule generates best case , worst case and conservative scenarios*/
			List&lt;String> ColumnDimensions=[];			
			List&lt;String> RowDimensions = [];
            List&lt;String> CustomDimensions = []
            List&lt;String> RevCustomDimensions = []
            List&lt;String> CustomDimMembers =[]
			List&lt;String> fixMemberNames = operation.grid.pov*.essbaseMbrName
			List&lt;String> povMembers =[];
            List&lt;String> povStdMembers =[];
            String strColDimName="";
            boolean isUnitsModel =false;
            String driverDimMember;
            int iCnt;
            int firstColumn;
			try{
            /*Get driver member*/
            Application app=operation.getApplication();            
			Cube qtp=operation.getCube(); 
			Dimension dim=app.getDimension(DimensionType.ACCOUNT,qtp);
        	if (dim.hasMember("OQP_Units",qtp)==true)
          	{
				isUnitsModel=true;
				driverDimMember="OQP_Last Year Units";
            }
			else
			{
				 isUnitsModel=false;
				 driverDimMember="OQP_Last Year Revenue";                    
			}   
            /*Reading user variable value to get source senario for copy*/
            UserVariable uv=app.getUserVariable("OEP_Scenario");
            def vScenario=uv.getValue();           
			StringBuilder cscript = new StringBuilder();
			cscript.append('''SET AGGMISSG ON;\n''');
			cscript.append('''SET UPDATECALC OFF;\n''');
            /*Get POV Members, Column Members and Row members and make corrosponding arrays*/
			def grid=operation.grid;
			List&lt;DataGrid.HeaderCell> pov=grid.getPov()
			List&lt;DataGrid.Row> rows = grid.getRows()
			for (DataGrid.Row row : rows) 
			{
				List&lt;DataGrid.HeaderCell> subRows = row.getHeaders();
				for(DataGrid.HeaderCell cell : subRows) 
				  {
					  String memName = cell.getEssbaseMbrName();
				   if (!RowDimensions.contains(memName))
				   {
				  	 RowDimensions.add('''@ICHILDREN("'''+memName +'''")''')				  
				   }     	 
				 }        
			}
			for (DataGrid.HeaderCell cell : pov)
			{
			   String mbrName = cell.getEssbaseMbrName();
			   String dimType = cell.getDimensionType();		  
			   String dimName = cell.getDimName();
				if(!dimType.equals("Scenario"))
				{
					if(dimType.equals("Currency")  ||  dimType.equals("Version") || dimType.equals("Year") || dimType.equals("Simple Currency"))
                    {
                    	    povStdMembers.add('''"'''+mbrName+'''"''');                                                	
                    }
                    else
                    {
                    		povMembers.add('''@Relative("'''+mbrName+'''",0)''');                     
                        	CustomDimensions.add('''"'''+dimName+'''"''');
                            CustomDimMembers.add('''"'''+mbrName+'''"''');
                    }                   
				}    
			}
            List&lt;List&lt;DataGrid.HeaderCell>> cols = grid.getColumns();
			for (List&lt;DataGrid.HeaderCell> cells : cols) 
			{
             firstColumn=0;
		 	for (DataGrid.HeaderCell cell : cells)  
			  {			  	
			   	String dimName = cell.getDimName();                
               	DimensionType dimType = cell.getDimensionType();
               if(!dimType.equals(DimensionType.SCENARIO) &amp;&amp; !dimType.equals(DimensionType.ACCOUNT) &amp;&amp; !dimType.equals(DimensionType.PERIOD))
				{
			   	if (!ColumnDimensions.contains(dimName))
				  {					
						ColumnDimensions.add(dimName)
                        strColDimName=dimName;
				  }			   
				 }
                firstColumn++;
			  	if (firstColumn==1) 
			  	break;                      
               }
                          
			 }
            
					   
		 	           
            /*Data copy from Source Scenario to Target Scenarios , Further, Applying growth percentage*/
			cscript.append('''FIX(@Relative("YearTotal",0),"BegBalance",''')
            cscript.append(povStdMembers.join(''',''')+''',''')
            cscript.append(RowDimensions.join(''',''')+''')\n''')
					
            if (ColumnDimensions.size()>0 || povMembers.size()>0)
            {
            cscript.append('''	FIX(''')
            	if (strColDimName.size()>0)
            	{
					if (CustomDimMembers.size()>0)
					{
						cscript.append('''@Relative("OEP_All '''+ strColDimName+'''",0),''')
						CustomDimensions.add(strColDimName);
					}
					else
					{
						cscript.append('''@Relative("OEP_All '''+ strColDimName+'''",0)''')
					}	
            	}
            cscript.append(povMembers.join(''','''))
			cscript.append(''')\n''');            
            
            }
			cscript.append('''		FIX(@Relative("OQP_Last Year Bookings",0),"OQP_Target Quota","OQP_Allocated Target Quota","OQP_Growth%")\n''')
			cscript.append('''			Datacopy "'''+vScenario+'''" to "OEP_Best Case";\n''')
            cscript.append('''			Datacopy "'''+vScenario+'''" to OEP_Conservative;\n''')
            cscript.append('''			Datacopy "'''+vScenario+'''" to "OEP_Worst Case";\n''')            
            cscript.append('''		ENDFIX\n''')		
            cscript.append('''		FIX("OQP_Target Quota","OQP_Allocated Target Quota")\n''') 	
			cscript.append('''				"OEP_Worst Case"( \n''')
            cscript.append('''					@CALCMODE(BOTTOMUP);\n''')
            cscript.append('''					"OEP_Worst Case"="OEP_Worst Case"+"OEP_Worst Case"*'''+rtps.OQP_WorstCasePer.getDoubleValue()/100+'''; \n''')
            cscript.append('''				) \n''')
            cscript.append('''				"OEP_Best Case"( \n''')
            cscript.append('''					@CALCMODE(BOTTOMUP);\n''')
            cscript.append('''					"OEP_Best Case"="OEP_Best Case"+"OEP_Best Case"*'''+rtps.OQP_BestCasePer.getDoubleValue()/100+'''; \n''')
            cscript.append('''				) \n''')
            cscript.append('''				"OEP_Conservative"( \n''')
            cscript.append('''					@CALCMODE(BOTTOMUP);\n''')
            cscript.append('''					"OEP_Conservative"="OEP_Conservative"+"OEP_Conservative"*'''+rtps.OQP_ConservativePer.getDoubleValue()/100+'''; \n''')
            cscript.append('''				) \n''')
            cscript.append('''		ENDFIX\n''')
            if (ColumnDimensions.size()>0 || povMembers.size()>0)
            {
				cscript.append('''	ENDFIX\n''')
            }
            /*Aggregate Custom Dimensions for first level children of Territory or Resource dimensions*/
            cscript.append('''	FIX("OEP_Worst Case","OEP_Best Case","OEP_Conservative")\n''')	
            
            if (CustomDimensions.size()>1)
             {
             	cscript.append('''		FIX(@Relative("OQP_Last Year Bookings",0),"OQP_Target Quota","OQP_Allocated Target Quota")\n''')
                for (iCnt=0;iCnt&lt;CustomDimensions.size()-1;iCnt++)
                {
                cscript.append('''			FIX(@RELATIVE('''+CustomDimensions[iCnt]+''',0))\n''')              
                }                
                for (iCnt=CustomDimensions.size()-1;iCnt>0;iCnt--)
                {
                cscript.append('''				AGG('''+CustomDimensions[iCnt]+''');\n''')                        
                cscript.append('''			ENDFIX\n''')
                }
                cscript.append('''			AGG('''+CustomDimensions[0]+''');\n''')
                cscript.append('''		ENDFIX\n''')
            }
            if (CustomDimensions.size()==1)
            {
            	cscript.append('''		FIX(@Relative("OQP_Last Year Bookings",0),"OQP_Target Quota","OQP_Allocated Target Quota")\n''')
             	cscript.append('''	 		AGG('''+CustomDimensions[0]+''');\n''')
                cscript.append('''		ENDFIX\n''')            
            }
            
            
            /*Recalculate Growth percentgates*/
            
			if (CustomDimMembers.size()>0)
			{
            	cscript.append ('''		FIX('''+CustomDimMembers.join(''',''')+''')\n''')					          		  
            }
			if (ColumnDimensions.size()>0)
            {
            	cscript.append('''			FIX(@ICHILDREN("OEP_All '''+ strColDimName+'''"))\n''')
            }
			cscript.append('''				"OQP_Growth%"''')
			cscript.append('''				( \n''')
			cscript.append('''					"OQP_Growth%"  = (("OQP_Target Quota"->"YearTotal"-"'''+driverDimMember+'''"->"YearTotal")/ "'''+driverDimMember+'''"->"YearTotal");\n''')
			cscript.append('''				) \n''')
            if (ColumnDimensions.size()>0)
            {
            	cscript.append('''			ENDFIX; \n''')
            }
            if (CustomDimMembers.size()>0)
			{
            	cscript.append('''		ENDFIX; \n''')
            }
            cscript.append('''	ENDFIX\n''')
            cscript.append('''ENDFIX\n''')
			println (cscript.toString())
			return cscript.toString();
			}catch(all) {
				throw new HspRuntimeException('Error occured while executing business rule');
			}		
		</script></rule></rules><components/><deployobjects><deployobject product="2" application="salespln" plantype="oep_qtp" obj_id="1" obj_type="1" name="OQP_SET TARGET WHAT IF"/></deployobjects></HBRRepo>